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Bienvenido a la Revista SOLOLINUX 


Sergio G. B. nuestro compañero, mentor, Maestro. 


Este mes la revista se ha quedado corta, no porque falten artículos 
(hay menos de los habituales) si no, porque no hemos sabido 
reemplazarle; Sergio nos ha dejado, aunque seguro que nos está 
observando desde su nuevo puesto. 


El pasado 22 de septiembre, ha fallecido por culpa de un maldito 
virus por desgracia muy famoso. 


Toda la comunidad está de luto y le echamos de menos. Era una 
inspiración para muchos, un guía incansable, rivalizaba en él su 
hambre de conocimientos y su basto saber acumulado pero, además, 
era un magnífico divulgador que nos sorprendía cada día, con un 
nuevo tema con su particular enfoque. 


Sergio, los que te conocimos, intentaremos seguir con tu legado, 


sabemos que así lo habrías querido; quizá no consigamos igualarte, 
pero seguiremos adelante mientras podamos. 


Gracias Sergio, hasta siempre. 
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CARTA AL LECTOR 


Estamos de luto: 

Estas líneas no solíamos escribirlas nosotros, siempre era Sergio G. B. 

Pero septiembre ha terminado con algo que no hubiéramos imaginado, y que nos ha golpeado en el corazón 
de nuestra comunidad. 


El cerebro y creador de la comunidad, amigo, compañero, mentor y maestro Sergio G. B. ha fallecido. 
Estamos desolados, pero sabemos que desde donde esté nos seguirá apoyando y guiando. 


Sergio G. B. fue y es una gran persona, que siempre ayudó sin mirar a quién, con una mentalidad libre como 
el software, y que supo dejar su huella marcada en esta nuestra comunidad, y en todo el panorama Open- 
Source. 


Así ha quedado reflejado por la comunidad Sololinux, que se ha volcado en este momento de dolor, como del 
resto de comunidades, lectores, patrocinadores y empresas del sector que nos han hecho llegar una multitud 
de ánimos, apoyos y condolencias a la comunidad, familiares y amigos. 


GRACIAS. 

Nos deja un legado y un camino marcado, para continuar con su misión como él hubiera querido. Así 
perdurará en el tiempo lo que entre él y todos hemos creado. 

Nuestro más sincero pésame a la familia, lamentando el dolor y reciban todo nuestro apoyo. 


A Sergio G. B.: 


Gracias por todo. Siempre estarás con nosotros. 
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NOTAS DE LOS LECTORES. GRACIAS 


Me he quedado muy apenado al enterarme hoy de la noticia, a 
pesar de conocer a Sergio únicamente a través del ciberespacio. 
Sus centenares de artículos destilan y atesoran muchísimo 
conocimiento, experiencia y pasión por lo que hacía. Nos deja 
todo un legado y es un ejemplo a seguir. Intercambié con él 
algunos correos y me demostró ser muy buena persona y me 
inspiró mucha confianza. A mí, como a otros compañeros que 
han intervenido, también me inspiró y animó a retornar a 
Linux y seguir aprendiendo. Que en paz descanse y que perviva 
su legado. 


Firmado: Roberto G. 


No me lo puedo creer. Descansa en paz Sergio. Gracias por tu 
obra. 
Mi más sentido pésame a la familia y a esta tu familia linuxera. 


Firmado: Luis 


A pesar de ser nuevo en la comunidad, soy un gran lector de 
sus artículos de la revista Solo Linux, en mi país a los hombres 
de sistemas como Sergio, decimos que no ha muerto, solo a 
subido a la nube, una gran pérdida... descanse en paz maestro... 


Firmado: Raul. 


Este comunicado me deja tan...descolocado?sin palabras? 
desconcertado....?y muy triste...cuántas veces me habrá 
ayudado....cuántas respuestas a un recién llegado a este mundo 
Linux....que descanse en paz, mucha fuerza y ánimos a su 
familia,y compañeros. Gracias Sergio por todos tus artículos y 
sabiduría compartida... 


Firmado: Jose Luis. 


Triste noticia, pero toda semilla germina y crece y ese será su 
legado. 

Que tenga un buen camino y mi sentido pésame para la 
familia. 


Firmado: Julio Boniel. 


Rayos, yo me di cuenta quien era él en días pasados porque le 
hice unas preguntas directas. No soy muy viejo en este grupo. 
Cuantos buenos artículos escribió Que sus parientes reciban 
consuelo y paz a sus restos. Espero podamos salir de este virus 
lo más rápido posible. 


Firmado: Drbn. 


Que root lo acompañe en el bucle donde el desee pasar su 
eternidad. 


Firmado: Nelson Sanchez. 


Que mala noticia... 


Mi más sentido pésame. 

Tengo poco tiempo en el grupo (unos 7 u 8 meses) 

Y muy al principio, en uno de esos días de mensajes, Sergio 
borró una de mis respuestas. 

Ya en lo privado, le aclaré que desde mi punto de vista, no 
había cometido ninguna falta. 

Luego de aclarar, las diferencias de idioma entre España y 
México ,llegamos a un sano empate. 

Pero a partir de ese momento, comenzamos en un par de 
ocasiones a compartir historias, ideologías, temas del trabajo, 
etc. 

En pocas palabras : todo un personaje. 

Lástima que se nos adelantó... 


Firmado: Héctor Anibal. 


Que noticia más triste y lamentable, mi más sentido pésame 
para sus familiares y amigos, me ayudo muchísimo con una 
antigua Pc que realmente gracias a él puse a funcionar 
nuevamente con una distro liviana que me recomendó, siempre 
leyendo sus artículos que descubrí en el poco tiempo que llevo 
en este canal, una gran pérdida su partida para todos nosotros 


Firmado: Jose David. 


Un intelectual tecnologo... hasta el ultimo suspiro por el 
software libre...sea x covid o lo que sea...estará en un plano 
espiritual donde compartira un conocimiento mas absoluto de 
lo humano incluyendo lo infinito ..numeros, programacion, 
ciencia, etc...esa SABIDURIA informatica que ahora el 
alcanzará...en el otro plano lo conocera todo...ojala su espiritu 
nos ayude en este plano...crear un mundo libre como ahora lo 
es el... 


Firmado: D. 


Una noticia fatídica. Sergio era una persona que siempre estaba 
atento a cualquier duda o sugerencia y hasta te hacía una 
publicación si era necesario para explicar algo que desconocías, 
y de paso así ayudar a otras personas que se pudieran 
encontrar con la misma inquietud... 


Mi más sentido pésame para la familia y todas las personas que 
de un modo u otro tuvimos la suerte de poder conocer un 
poquito (o un mucho!) a este gran amigo. Ojalá hubiera un 
CTRL+Z para esto... 


Firmado: Benny Beat. 
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La herramienta passwd, tiene la 
particularidad de permitir la 
modificación de contraseñas, de 
todas las cuentas de usuario 
incluidas en un sistema Linux. 
Cuando trabajas con este comando, 
debes tener presente que si eres un 
usuario normal, solo podrás 
cambiar la contraseña de tu propia 
cuenta. Por otro lado tenemos el 
superusuario o usuario root, que 
si tiene permisos para modificar 
cualquier cuenta de usuario. 


Muchos usuarios desconocen que 
con esta herramienta, se pueden 
hacer muchas más operaciones 
aparte de modificar el password. 
También podemos imprimir O 
modificar la información de la 
cuenta, la shell de inicio e incluso 
las fechas de caducidad, entre 
otras. 


www.sololinux.es. 


Uso del comando 
passwd con 
ejemplos 
Su función principal es establecer 
una contraseña de usuario 0, 


modificar la contraseña existente. 
La sintaxis es la siguiente: 


passwd [usuario] 


Si quieres modificar la contraseña 
del usuario actual, no es necesario 
definir ningún usuario. Vemos un 
ejemplo completo, en el cual podrás 
comprobar sus pasos. 
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Solicita la contraseña actual. 

introduces la nueva. 

Repites la nueva. 

La seguridad del sistema no admite la contraseña nueva por ser 
demasiado simple. 

Tipeamos un password más complejo. 

Lo repites. 

Se acepta y actualiza a la nueva contraseña. 


sergiofdemo-sololinux:"“$ passwd 

Cambiando la contraseña de sergio. 

(actual) contraseña de UNIX: 

Introduzca la nueva contraseña de UNIX: 

Vuelva a escribir la nueva contraseña de UNIX: 
Bad: new password is too simple 

Introduzca la nueva contraseña de UNIX: 

Vuelva a escribir la nueva contraseña de UNIX: 
passwd: contraseña actualizada correctamente 
sergiofdemo-sololinux: “$ 


Ahora vamos a bloquear la cuenta de un usuario haciendo que su contraseña 
caduque, después la desbloqueamos siguiendo el mismo proceso. Es 
evidente que para realizar este proceso debemos ser root. 

+ Bloquear cuenta 

passwd -1l sergio 


+ Desbloquear cuenta 
passwd -u sergio 


La imagen nos muestra el proceso completo. 


rooteademo -sololinux: 
rootademo-sololinux: 
passwd: información 
rootedemo-sololinux: 
rootedemo-sololinux: 
passwd: información 
rootademo -sololinux: 


www. .sololinux.es 
passwd -1l sergio 
caducidad de la contraseña cambiada. 


passwd -u sergio 
caducidad de la contraseña cambiada. 


Si quieres, también puedes establecer la duración mínima y máxima en días, 
de la caducidad de la contraseña. 


* Duración minima 
passwd -n 5 [usuario] 
* Duración maxima 
passwd -x 500 [usuario] 


rootademo-sololinux: 
rootfademo-sololinux: 
passwd: información 
rootfademo-sololinux: 
rootfademo-sololinux: 
passwd: información 
rootfademo-sololinux: 


passwd -n 5 sergio 
caducidad de la contraseña cambiada. 


passwd -x 500 sergio 
caducidad de la contraseña cambiada. 


Con la opción «-S», podemos visualizar el estado de la contraseña de 
usuario. 


passwd -S [usuario] 


rootademo-sololinux:-+* 


rootademo-sololinux:-* passwd -S sergio 
sergio P 09/02/2021 5 500 7 -1 
rootademo -sololinux:-+ 


Es interesante lanzar un aviso al usuario, comunicándole que su contraseña 
caducara pronto. Establecemos los días antes de que caduque con la 
opción «-w». 


passwd -w [dias] [usuario] 


En el ejemplo también vemos como ha cambiado el status de la contraseña. 


rooteademo-sololinux: + 
rootedemo-sololinux:“* passwd -w 10 sergio 
passwd: información de caducidad de la contraseña cambiada. 


rootedemo-sololinux: + 
rootedemo-sololinux:“* passwd -S sergio 
sergio P 09/02/2021 5 500 10 -1 
rooteademo-sololinux: + 


Este último comando que te propongo no es recomendable, pero si es útil en caso de que olvides la contraseña de 
algún usuario. La opción «-d» borra el password del usuario indicado. 


rootfdemo -sololinux: + www.sololinux.es 
rootademo-sololinux:-+ passwd -d sergio 
passwd: información de caducidad de la contraseña cambiada. 
rootfademo -sololinux: + 

Con el argumento «-h», revisamos las opciones admitidas por el comando. 


Se imprime la salida. 


sergiofsololinux:w$ passwd -h 
Modo de uso: passwd [opciones] [USUARIO] 
Opciones: 
-a, --all informa del estado de las contraseñas de 
todas las cuentas 
-d, --delete borra la contraseña para la cuenta indicada 
-e, --expire fuerza a que la contraseña de la cuenta 
caduque 
-h, --help muestra este mensaje de ayuda y termina 
-k, --keep-tokens cambia la contraseña sólo si ha caducado 
-=i, --inactive INACTIVO establece la contraseña inactiva después de 
caducar a INACTIVO 
=1, --lock bloquea la contraseña de la cuenta indicada 
-n, --mindays DÍAS _MIN establece el número mínimo de días antes 
de que se cambie la contraseña a DÍAS_MIN 
-q, --quiet modo silencioso 
=r, --repository REP cambia la contraseña en el repositorio REP 
-R, --root CHROOT_DIR directorio en el que hacer chroot 
=S, --status informa del estado de la contraseña la cuenta 
indicada 
-u, --unlock desbloquea la contraseña de la cuenta indicada 
-W, --warndays DÍAS_AVISO establece el aviso de caducidad a DÍAS_AVISO 
-x, --maxdays DÍAS _MAX establece el número máximo de días antes de 
cambiar la contraseña a DÍAS_MAX 
sergiofEsololinux:w$ 


Si aún necesitas más información, este comando dispone de un completo manual integrado. 


man passwd 


Canales de Telegram: Canal SoloLinux — 


SOLOLIN! 


SOFTWARE 


Comparar archivos y carpetas con meld 
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Comparar archivos y carpetas 
con la herramienta meld 


Comparar archivos y directorios es una tarea bastante 
común, en especial para los desarrolladores. Para este 
tipo de operaciones, en linux disponemos del fantástico 
comando diff, que busca diferencias por caracteres, 
líneas, tamaño y mucho más. Como es lógico, diff opera 
en terminal, y esto puede suponer un engorro para los 
usuarios más noveles, por ello se creó la herramienta 
Meld. 


Meld es una interfaz gráfica del comando diff, 

considerada por la comunidad Linux como una de las 

mejores herramientas para realizar comparaciones entre 

archivos, directorios y proyectos de control de versiones. 

Es ampliamente utilizada por los usuarios normales y, 

también por desarrolladores de aplicaciones para 

verificar sus desarrollos diarios. Algunas de las 

características más destacadas, son: 

» Ofrece una exhaustiva comparación de archivos / 
carpetas (bidireccional y tridireccional). 

+ Capacidad de combinar archivos y carpetas, gracias 
a la función Auto Merge. 

+ Permite el resaltado de sintaxis y la administración 
de archivo. 

» Sencilla y agradable interfaz gráfica. 

+ Soporte para sistemas de control de versiones 
(Git, Mercurial, Bazaar y SVN). 

* Permite ver el estado de las versiones en el sistema 
de control. 

* Soporta la integración con herramientas en línea de 
comandos (git y mergetoo!l). 


En el artículo de hoy, vemos como instalar Meld en 
nuestra distribución Linux preferida, además de un 
sencillo ejemplo de uso que resultara de tu interés. 


4 meld 


Comparar archivos y carpetas 
con meld 
No vamos a enumerar los requisitos para el uso de la 


herramienta, porque son comunes en cualquier 
distribución moderna. Python 3.x, GTK 3.x, etc. 
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Selecciona el comando de instalación de la herramienta, 
dependiendo de tu sistema. 
Debian, Ubuntu, Mint y derivados: 


sudo apt-get install meld 


Fedora, CentOS, Alma Linux y derivados: 


sudo dnf install meld 
Ho 
sudo yum install meld 


Arch Linux, Manjaro y derivados: 


sudo pacman -S meld 


SUSE, OpenSUSE y derivados: 


sudo zypper install meld 


sudo apt-get install meld www.sololinux.es 


. Hecho 


. Hecho 
etes NUEVOS: 


0 para eliminar y 0 no actualizados. 


adicional después de esta operación. 
J bionic/universe amd64 meld all 3.18.0-6 [494 kB] 


3+linuxmint8) ... 
O0ubuntu0.18.04.8) ... 


Para nuestra comparativa, tomamos como ejemplo el 
script del artículo «Modificar la cantidad de Kernel 
que se guardan en Ubuntu«. Usando meld, 
compararemos el archivo original «apt-auto- 
removal» con el modificado «nuevo-apt-auto- 
removal». Verás que fácil. 


Desde el menú de aplicaciones de tu entorno de 
escritorio preferido, podrás lanzar la herramienta Meld. 
De forma automática aparece una ventana interactiva, 
en la cual elegimos el archivo primario (principal). Una 
vez seleccionado, pulsa en «Comparar». 


2 Nueva comparación - "0 


Meld Archivo Editar Cambios Ver 


o . 
Y 7 Www:sololinúuxies 
Nueva comparación 
Nueva comparación 
S = pi 


Comparación de archivos Comparación de carpetas Vista de control de versión 


Ly] 
Bb 


(Ninguno) (Ninguno) 


Comparación de 3 vías 


Comparación en blanco Comparar 


Se abre la herramienta con dos ventanas, en las cuales 
se compararan los archivos. Haz clic donde te indica la 
flecha de la siguiente imagen, para seleccionar el 
segundo archivo. 
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pa apt-auto-removal — <sin nombre> - uv. 0 


Meld Archivo Editar Cambios Ver 


.. 
o tii Guardar Ey Deshacer 


_) apt-auto-re...sin nombre>  * 


Ue] 


RA EX aptauto-removal 


those kernel packages that are: 

ersior 

alled for 

version (as determined by debian version number) 


kernel version 


ES 
ES 
E 
Ea 
H 
H 
H 
H 
E 
H 


INF DP)" || APT_ CONF D= 
S[APT_CONF_D)/Olautoremove-ke 


test = 
config fil 


ig shell DPKG Dir::bin::dpkg/f) 

| DPKG="/usr/bin/dp 
PKG)" -1 awk */”[ 
mM (linuxx | kfreeb 
st="$(echo "$list" | « 


lon="$ 


YE 
WwWw:sololinúuxies 


Z (Ninguno) 


Lín 87, Col 25 INS 


Como puedes ver en la siguiente imagen, las diferencias están marcadas por colores. El tono verde claro, indica que 
esa zona al completo (en este caso caracteres) no se encuentra en el archivo primario. Al observar detenidamente, 
vemos que existe una flecha pequeñita en el segundo archivo. Si pulsas en ella... toda la zona marcada en verde se 
clonara al archivo primario. 


Las líneas que tenemos en azul, son diferencias en espacios que en nuestro caso no influyen para nada en el buen 
funcionamiento del script. Una vez tengas todos los cambios realizados, puedes guardar el archivo. Es así de simple. 


a] 


eS apt-auto-removal* — nuevo-apt-auto-removal a 


Meld Archivo Editar Cambios Ver 
o la ee... 5 vee 5 4 Y Q WwWwW:Ssololinúuxies 


7 apt-auto-re...uto-removal 


W ES aptauto-removal a RA EX nuevo-apt-auto-removal pas 
set -e set -e 
* Mark as not-for-autoremoval those kernel packages that are: $ Mark as not-for-autoremoval those kernel packages that are: 
* - the currently booted version * - the currently booted version 
** - the kernel version we've been called for ** - the kernel version we've been called for 
—% - the latest kernel version (as determined by debian version number) * - the latest kernel version (as determined by debian version number) Ñ 
** - the second-latest kernel version ** - the second-latest kernel version 
$$ Ñ 


* In the common case this results in two kernels saved (booted into the 
* second-latest kernel, we install the latest kernel in an upgrade), but 


* In the common case this results in two kernels saved (booted into the 
* second-latest kernel, we install the latest kernel in an upgrade), but 


¡PH 4 can save up to four. Kernel refers here to a distinct release, which can * can save up to four. Kernel refers here to a distinct release, which can 
od potentially be installed in multiple flavours counting as one kernel .| _** potentially be installed in multiple flavours counting as one kernel. [a 
a 
Bd eval $(apt-config shell APT_CONF_D Dir::Etc::parts/d) a 
test -n "S(APT_CONF_D)" || APT_CONF_D="/etc/apt/apt.conf.d" 
[config file="$([APT_CONF_D)/Olautoremove-kernels" a 
eval $(apt-config shell DPKG Dir::bin::dpkg/f) eval $(apt-config shell APT_CONF_D Dir::Etc::parts/d) 
um test -n "S$DPKG" || DPKG="/usr/bin/dpkg" test -n "S(APT_CONF_D)" || APT_CONF _D="/etc/apt/apt.conf.d" S 
config file="S(APT_CONF_D)/Olautoremove-kernels" 
list="$("S$(DPKG)" -1 | awk '/“[ih][“nc][ ]+(linux|kfreebsd|gnumach) -image- [0 
| sed -e si (linuxa | kfreebsdr | gnumachY) -image-+4" -e 'st:[": Jia 4 4)" eval $(apt-config shell DPKG Dir::bin::dpkg/f) 
debverlist="$(echo "$list" | cut -d' ' -f 2 | sort --unique --reverse --vers test -n "$DPKG" || DPKG="/usr/bin/dpkg" 
if [ -n "$1" ]; then list="$("S(DPKG)" -1 | awk '/”[ih][“nc][ ]+(linux|kfreebsd|gnumach) -image- [9 
installed version="$(echo "$list" | awk "$1 == W"$11" ([ print 1$2;em)' | sed -e 'si (linux |kfreebsdl | gnumach1) -image-+Ht' -e "st: [":]+ 4 4')" 
fi h debverlist="$(echo "$list" | cut -d' ' -f 2 | sort --unique --reverse --vers 
unamer="$(uname -r | tr *[A-Z]' '[a-z]')" N 
if [ -n "Sunamer" ]; then Yo if [ -n "$1" ]; then Pa 
Lal mm 


running version="$(echo "$list" | awk "Y$1 == Y"$Sunamerí" ( print 1$m) | € installed version="$(echo "$list" | awk "1$1 == W"$11" ( print 1$2;exit; 
fi fi 
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Uso del comando. 


Www. CICAD es 


i con ejemplos | 


Al iniciar un sistema Linux, el kernel identifica los 
dispositivos de hardware disponibles en el sistema. A 
medida que el kernel los va detectando e identificando, 
se generan unos registros que se escriben en un buffer 
(en anillo) del Kernel. Este buffer en anillo, también 
conocido como buffer cíclico o circular, es específico 
para manejar el registro interno del Kernel. 


Saber leer este registro es importante, pues más de una 
vez puede salvar tu sistema. Recuerda que como en 
cualquier registro, en este también se guardan los 
errores. Con el comando dmesg no solo podrás ver 
todo el registro, sino que además podrás identificar de 
manera simple los errores por tipo, algo especialmente 
útil para nosotros. Vemos cómo se trabaja con este 
comando. 


1024414 
: 64 pages used for memmap 
: 1142 pages reserved 
: 3982 pages, LIFO batch:0 
: 7753 pages used for memmap 
: 496144 pages, LIFO batch:63 
: 8192 pages used for memmap 
: 524288 pages, LIFO batch:63 
: Local APIC address Oxfee00000 
: IRQO used by override. 
: IRQ9 used by override. 
: update [mem 0x78865000-0x7886efff] usable ==> reserved 


Uso del comando dmesg con 
ejemplos 


Su forma de uso simple, imprime el buffer al completo. 


0 


sergiofsololinux:"$ dmesg 
E 0.000000] Linux version 5.4.0-81-generic (builddalgw01- 
amd64-051) (gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntul-18.04)) 
H91-18.04.1-Ubuntu SMP Fri Jul 23 13:36:29 UTC 2021 (Ubuntu 
5.4.0-81.91-18.04.1-generic 5.4.128) 
[ 0.000000] Command line: BOOT_IMAGE=/bo0t/vmlinuz-5.4.0- 
81-generic root=UUID=77674f63-7f05-4b96-a2aa-125cd616afcb ro 
fsck.mode=force fsck.repair=yes 
0.000000] KERNEL supported cpus: 
0.000000] Intel GenuinelIntel 
.000000] AMD AuthenticAMD 
.000000] Hygon HygonGenuine 
.000000] Centaur CentaurHauls 
zhaoxin Shanghai 
x87 FPU will use FXSAVE 


.000000] 
.000000] x86/fpu: 
.000000] BIOS-provided physical RAM map: 


.000000] BIOS-e820: 
0x000000000006efff] usable 
| 0.000000] BIOS-e820: [mem 0x000000000006f000- 
0x000000000006ffff] ACPI NVS 


[mem 0x0000000000000000- 
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E 0.000000] BIOS-e820: 
0x000000000008ffff] usable 
[ 0.000000] BIOS-e820: [mem 
0x000000000009ffff] reserved 
[ 0.000000] BIOS-e820: [mem 
0x000000001fffffff] usable 
[ 0.000000] BIOS-e820: [mem 
0x00000000201fffff] reserved 
[ 0.000000] BIOS-e820: [mem 
0x000000007a40efff] usable 
[ 0.000000] BIOS-e820: [mem 
0x000000007aebefff] reserved 
E 0.000000] BIOS-e820: [mem 
0x000000007bfbefff] ACPI NVS 
[ 0.000000] BIOS-e820: [mem 
0x000000007bffefff] ACPI data 
[ 0.000000] BIOS-e820: [mem 
0x000000007bffffff] usable 
[ 0.000000] BIOS-e820: [mem 
0x00000000e00f8fff] reserved 
E 0.000000] BIOS-e820: [mem 
0x00000000fed01fff] reserved 
[ 0.000000] BIOS-e820: [mem 
0x00000000ffffffff] reserved 
[ 0.000000] BIOS-e820: [mem 
0x000000017fffffff] usable 
.000000] NX (Execute Disable) protection: active 
.000000] e820: update [mem 0x742f7018-0x74307057] 
==> usable 
000000] e820: 
==> usable 
.000000] extended physical RAM map: 
.000000] reserve setup_data: [mem 0x0000000000000000- 
0x000000000006efff] usable 
[ 0.000000] reserve setup_data: 
0x000000000006ffff] ACPI NVS 


[mem 0x0000000000070000- 
0x0000000000090000- 
0x0000000000100000- 
0x0000000020000000- 
0x0000000020200000- 
0x000000007240f000- 
0x000000007aebf000- 
0x000000007bfbf000- 
0x000000007bfff000- 


0x00000000e00f8000- 


0x00000000fed01000- 
0x00000000ffa00000- 


0x0000000100000000- 


usable 
E 0. 
usable 


update [mem 0x742f7018-0x74307057] 


[mem 0x000000000006f000- 


0.009999] 
0.009999] 


: Update [ 
update [mem 0x742 FTO18-Ox7a3o7OS 


Cuando tienes errores, lo recomendable es que apliques 
los filtros que vienen incorporados con el comando. Así 
podrás identificar el error, de forma sencilla y rápida. Los 
filtros disponibles son los siguientes: 


+  emerg - Error que impide el funcionamiento del 
sistema correctamente. 


+ alert - Error que requiere intervención inmediata. 
*  crit —- Sistema bajo condiciones críticas. 

*  err- Sistema bajo condiciones de error. 

» — warn - Advertencias del sistema. 

+ debug - Advertencias de depuración. 


* notice - Condiciones normales, pero debes prestar 
atención al aviso. 


* info - Información general. 
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Estos filtros de mensajes, los debes usar con esta 
sintaxis... 


dmesg --level=alert,[fil 


Ejemplos de uso. 


dmesg --level=alert,emerg 
HH 
dmesg 
HH 
dmesg 
HH 
dmesg 
HH 
dmesg 
HH 
dmesg 
HH 
dmesg 
HH 
dmesg 


--level=alert,alert 


--level=alert,err 


--level=alert,crit 
--level=alert,warn 
--level=alert,debug 
--level=alert,notice 


--level=alert,info 


Imagen con ejemplos de uso, en el que podemos 
observar una serie de errores y alertas. Tendremos que 
revisar que sucede, aunque en realidad es una 

vieja tarjeta SD (no me preocupa mucho). 


$ 
:-$ dmesg -- 
:-$ dmesg -- 
:-$ dmesg -- 
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level=alert,crit 
level=alert,err 


:-$ dmesg --level=alert,warn 


: TPM Final Events table missing or invalid 
: Set to 'normal', was 'performance' 

: EISA: Cannot allocate resource for mainboard 

: Cannot allocate resource for EISA slot 1 

: Cannot allocate resource for EISA slot 2 

: Cannot allocate resource for EISA slot 3 

: Cannot allocate resource for EISA slot 4 

: Cannot allocate resource for EISA slot 5 

: Cannot allocate resource for EISA slot 6 

: Cannot allocate resource for EISA slot 7 

: Cannot allocate resource for EISA slot 8 

: WOBJ data block query control method not found 
: can't disable ASPM; 0S doesn't have ASPM control 
: loading out-of-tree module taints kernel. 
: module init start 
: rtl8723de v5.1.1.8_21285.20171026 
: build time: Aug 17 2021 10:20:01 
: rtl8723de BT-Coex version = BTCOEX20170111-1414 
: module init ret=0 
: Volume was not properly unmounted. Some data may be corrupt. Please run fsck. 
: Successfully started. 
: Successfully started. 
: Volume was not properly unmounted. Some data may be corrupt. Please run fsck. 


También tienes la opción de imprimir el buffer y, 
posteriormente borrar el ciclo del anillo. 


sergiofsololinux:“$ dmesg -C 

[12501.582069] usb 1-4: USB disconnect, device number 10 
[12503.462291] usb 1-4: new high-speed USB device number 11 
using xhci_hcd 

[12503.622454] usb 1-4: New USB device found, idVendor=0bda, 
idProduct=0177, bcdDevice=77.11 

[12503.622463] usb 1-4: New USB device strings: Mfr=1, 
Product=2, SerialNumber=3 

[12503.622469] usb 1-4: Product: USB2.0-CRW 

[12503.622475] usb 1-4: Manufacturer: Generic 

[12503.622479] usb 1-4: SerialNumber: 20121112761000000 
[12503.630446] ums-realtek 1-4:1.0: USB Mass Storage device 
detected 
[12503.635461] 
[12504.652987] 
SD/MMC/MS PRO 
[12504.654874] 
0 
[12505. 
blocks: 
[12505. 
[12505. 
[12505. 
cache: 
[12505. 
[12505. 
disk 
dmesg: 


scsi host2: usb-storage 1-4:1.0 

scsi 2:0:0:0: Direct-Access 
1.00 PQ: 0 ANSI: 4 

scsi 2:0:0:0: Attached scsi generic sgl type 


Generic- 


743088] sd 2:0:0:0: [sdb] 1950720 512-byte logical 
(999 MB/953 MiB) 

7434241] sd 2:0:0: [sdb] Write Protect is off 

7434271 sd 2:0 : [sdb] Mode Sense: 2f 00 00 00 

7437591] sd 2:0:0:0: [sdb] Write cache: disabled, read 

enabled, doesn't support DPO or FUA 

7638331] sdb: sdb1 


765578] sd 2:0:0:0: [sdb] Attached SCSI removable 


fallo al leer el «buffer» del núcleo: Operación no 
permitida 
sergiofsololinux: “$ 


Ahora especificamos el dispositivo del cual quieres ver 
los mensajes, en nuestro caso USB. 


dmesg | grep -i usb 


grep -i usb 
disconnect, device number 10 
: new high-speed 


.582069] 
.462291] 
.622454] 
.622463] 
.622469] 


device number 11 using xhci_hcd 
device found, idVendor=0bda, idProduct=0177, bcdDevice=77.11 
: New device strings: Mfr=1, Product=2, SerialNumber=3 
: Product: 2.0-CRW 
.622475] -4: Manufacturer: Generic 
.622479] -4: SerialNumber: 20121112761000000 
.630446] ums-realtek 1-4:1.0: Mass Storage device detected 
.635461] scsi host2: -storage 1-4:1.0 
$ 


Si tienes problemas con el anillo, puedes probar a 
reducir o aumentar su tamaño. 


: New 
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dmesg -s 1024 


Es evidente, que este comando tiene muchas más 
opciones y filtros. Si quieres aprender más sobre él, 
revisa su manual integrado en consola. 


man dmesg 


Canales de Telegram: 


Y (£) (9) (9) 


designed by 'S freepik 


SEGURIDAD 


Restringir la shell de usuario con rbash 


En Linux, al igual que en otros sistemas derivados 

de UNIX, al crear un nuevo usuario se le asigna 

un shell predeterminado (normalmente /bin/bash). Esto 
quiere decir que un usuario con suficientes 
conocimientos, puede moverse libremente por otros 
directorios a los cuales no debería tener acceso, o 
incluso ejecutar alguna acción que dañe a otros 
usuarios. 


Para evitar situaciones tan desagradables como las 
mencionadas anteriormente, existe rbash. Rbash, 
también conocido como restricted shell, tiene la 
capacidad de restringir las operaciones que un usuario 
(o varios), puede realizar en línea de comandos. En 
este artículo vemos como hacer esta operación, de 
manera sencilla y rápida. 


Por ejemplo, si ejecutamos el modo simple rbash, 
O bash con la opción -r en la invocación, el shell se 
restringe automáticamente el usuario actual. Volverá a 
su estado normal al reiniciar el entorno. Observa la 
imagen de ejemplo. 

$ 

:-$ cd Descargas 

$ 


$ rbash 
$ cd 


rbash: cd: restringido 


Restringir la shell de usuario con 
rbash 


Un modo restringido se usa para configurar un entorno 

más controlado que el estándar. Su comportamiento y 

forma de operar es idéntico a bash, con la excepción de 

lo que no está permitido. Vemos un listado de lo no 

permitido, más habitual. 

* Cambiar de directorio con el comando cd. 

+ No se permite modificar los valores 
de SHELL, PATH, ENV o BASH_ENV., 

+ Comandos, secuencias o nombres que 
contengan «/», como carácter o argumento. 

+ Archivos que contengan una barra como argumento 
para la opción -p del propio hash. 

- Importar definiciones de funciones desde el entorno 
de inicio de shell. 

* Analizar el valor de SHELLOPTS desde el entorno 
de inicio shell. 

* — Redirigir salidas usando los operadores de 
redirección >, > |, <>, > €, 4> y >>. 

+ Usar exec para reemplazar el shell con otro 
comando. 

+ Agregar o eliminar comandos integrados con las 
opciones -f y -d, del comando enable. 

+ Uso del comando enable builtin para habilitar 
funciones shell, que están deshabilitadas. 

+ Desactivar cualquier modo de salir del modo 
restringido. 

+ Alguna más de menor importancia. 


SOLOLINUX 
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Si queremos restringir solo a un usuario, modificamos su 
entorno de inicio en «$HOME/.bash_profile», con un 
sencillo script. En el home del usuario, creamos el 
archivo correspondiente. 


sudo nano .bash_profile 


Copia y pega lo siguiente. 


* .bash_profile 

$* Get the aliases and functions 

if [ -f =/.bashrc ]; then 

. “/.bashrc 

fi 

* User specific environment and startup programs 
PATH=$PATH: $HOME/bin 

export PATH 

bash -r 


Guarda el archivo, cierra el editor y reinicia el entorno de 
inicio del usuario en particular. Ahora probamos que 
funciona correctamente. 


cd /etc/ 
cd /tmp/ 
$ 


=$ cd /etc/ 
bash: cd: restringido 
imn$ 


:-$ cd /tmp/ 


bash: cd: restringido 
$ www.sololinux.es 


Otra opción es modificar la shell predeterminada. 


chsh -s /bin/rbash 


También por usuario. 


chsh -s /bin/rbash usuario 
$ 


$ sudo chsh -s /bin/rbash sergio 
$ 


De todas formas, si tienes varios usuarios lo normal es 
imponer las mismas restricciones a todos. El 
superusuario jamás tendrá restricciones. En este caso 
(recomendable), creamos un enlace simbólico 

en /bin de bash a rbash, ningún usuario tendrá más 
permisos que los necesarios para su trabajo. 


sudo cd /bin 
sudo ln -s bash rbash 


Nota: En algunas distribuciones linux la URL puede 
variar, por ejemplo la ruta Jusr. 
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Seguro que tienes multitud de documentos PDF 
almacenados en tu sistema. Deshacerte de ellos no es 
una Spa ra son manuales interesantes y las 

revi , tal vez sea interesante hacer una 
copia de a pero tienes poco espacio y 
demasiados GB en pdf. 


Una excelente solución es combinar varios archivos PDF 
en un solo PDF, así podrás administrar, visualizar o 
realizar copias de seguridad de manera más eficiente y 
rápida. PDFtk Server es una herramienta de línea de 
comandos, que entre otras muchas cosas nos permite 
combinar rápidamente varios archivos PDF en uno 
solo. 


PDFtk, también conocido como PDF Toolkit, tiene una 

versión compatible con Linux conocida como PDFtk 

Server que nos permite fusionar documentos PDF, 

dividir PDF en nuevos documentos, rotar páginas, 

descifrar y cifrar, actualizar metadatos, aplicar marcas de 

agua y mucho más. Vemos sus características. 

* Combinar documentos PDF o clasificar escaneos de 
páginas PDF. 

e — Dividir páginas PDF en un nuevo documento. 

+»  Rotar documentos o páginas PDF. 

»  Cifrar o descifrar documentos con contraseña. 

+ Rellenar formularios PDF con datos X / FDF. 

* Generar plantillas FDF desde formularios PDF. 

* Aplicar marca de agua en fondo o un sello en primer 
plano. 

* Generar informes de métricas, marcadores y 
metadatos del documento. 

+ Agregar o actualizar marcadores o metadatos PDF. 

+ Adjuntar archivos a páginas y documentos PDF. 

+  — Desempaquetar archivos adjuntos. 

* Descomprimir y recomprimir secuencias de páginas. 

+ Reparar documentos PDF dañados (si es posible). 


Combinar archivos pdf con 
PDFtk en uno solo 


Lamentablemente, la herramienta ha desaparecido de 
los repositorios oficiales de muchas distribuciones 
linux. Es una consecuencia del daño que está haciendo 
Canonical y sus paquetes snap, al intentar centralizar 
todo en una misma plataforma de la que ellos son 
propietarios (parecemos ovejas). 


Es cierto que podrías instalarlo desde su código fuente, 
pero claro... cada distribución tiene su propio método y 


sus propias librerías, así que hacemos una excepción e 
instalamos la herramienta desde snap. 


sudo snap install pdftk 


:-$ sudo snap install pdftk 
Se ha instalado pdftk 2.02-4 por Scott Moser (smoser) 


La sintaxis para combinar varios documentos o archivos 
en uno, es muy simple. Observa. 


pdftk archiv 
nuevo-archivo 


vo3.pdf cat output 


En nuestro ejemplo de uso, vamos a fusionar los cinco 
primeros números de la revista SoloLinux. En nuestro 
caso nos movemos a la carpeta descargas y, para una 
mayor comodidad (copiar y pegar) listamos el contenido. 


:-/Descargas$ 

:-/Descargas$ ls 
REVISTA _SOLOLINUX_NO1_FEBRERO_2019.pdf REVISTA _SOLOLINUX_NO4 MAYO 2019.pdf 
REVISTA SOLOLINUX_NO5 JUNIO 2019.pdf 


REVISTA _SOLOLINUX_NO2 MARZO 2019.pdf 
REVISTA SOLOLINUX_NO3 ABRIL_2019.pdf 
:-/Descargas$ 


Ahora ejecutamos el siguiente comando. 


pdftk REVISTA_SOLOLINUX_NO01_FEBRERO_2019.pdf 
REVISTA_SOLOLINUX_N02_MARZO_2019.pdf 
REVISTA_SOLOLINUX_NO3_ABRIL_2019.pdf 
REVISTA_SOLOLINUX_N04_MAYO_2019.pdf 
REVISTA_SOLOLINUX_NO5_JUNIO_2019.pdf cat output 5-numeros- 


de-sololinux.pdf 


AS 
Carpeta personal 


Escritorio 


Documentos 2019.pdf  2019.pdf 


2019.pdf 
Imágenes 
Música 


ES 


Papelera 


Otras ubicaciones 


Puedes aprender más sobre la herramienta, ejecutando 
el comando en modo simple. 


pdf tk 


Verás algo similar a lo siguiente. 


sergiofdemo-sololinux:"w 
SYNOPSIS 

pdftk <input PDF files | - | PROMPT> 

input_pw <input PDF owner passwords | PROMPT> ] 

<operation> <operation arguments> ] 

output <output filename | - | PROMPT> ] 

encrypt_40bit | encrypt_128bit ] 

allow <permissions> ] 

owner_pw <owner password | PROMPT> ] 

user_pw <user password | PROMPT> ] 

flatten ] [ need_appearances ] 

A | 

keep_first_id | keep_final_id ] [ drop_xfa ] [ drop_xmp ] 

verbose ] [ dont_ask | do_ask ] 

Where: 

<operation> may be empty, or: 
[ cat | shuffle | burst | rotate | 

generate_fdf | fill_form | 

background | multibackground | 

stamp | multistamp | 

dump_data | dump_data_utf8 | 

dump_data_fields | dump_data_fields_utf8 | 

dump_data_annots | 

update_info | update_info_utf8 | 

attach_files | unpack_files ] 

For Complete Help: pdftk --help 
sergiofdemo-sololinux:w$ 


Para más ayuda usa help. 


$ pdftk 
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Cambiar de interfaz gráfica a línea de 


comandos con TTY 


TTY es el acrónimo de 
TeleTYpewriter, y tomamos su 
nombre porque en los comienzos de 
UNIX, los terminales de usuario que 
conectaban a viejas computadoras 
eran en realidad... teletipos 
comunes o teletipos 
electromecánicos, también 
conocidos como máquinas tty. 


y 


Desde entonces, el nombre TTY se familiarizó con la 
línea de comandos hasta nuestros días, hasta tal punto 
que se sigue usando en consolas de texto. Actualmente, 
la cosa ha cambiado y todas las consolas basadas en 
texto son consolas virtuales, en vez de las vetustas 
consolas físicas. Por otro lado, tenemos el comando tty 
que imprime el nombre de archivo del terminal 
conectado a la entrada estándar. 

Las funciones TTY son muchas y variadas, pero 
nosotros (en este artículo) nos vamos a centrar en como 
saltar de tu entorno de escritorio gráfico, a la línea de 
comandos de forma sencilla, rápida y reiniciando la 
sesión. 


=$ 
:-$ tty --version 
8.28 


ware Foundation, Inc. 
versión 3 o posterior 


y redistribuirlo. 


Escrito por David MacKenzie. 


Cambiar de interfaz gráfica a 
línea de comandos con TTY 


Puedes pensar que no tiene ningún sentido este artículo, 
que si quieres usar la línea de comandos ya tienes la 
terminal que te ofrece tu escritorio. Bueno... ya verás 
como ahora mismo comprenderás la utilidad de TTY y, 
como se ejecuta en la siguiente tabla. 


TTY Uso final Secuencia de acceso 


tty1 nea de comandos trl + Alt + 


Con el comando who puedes identificar las 
ejecuciones, así como el estado actual. En la siguiente 
imagen, verás que la actual es tty7. 


who 
2021-09-08 18:32 
2021-09-08 10:02 (:0) 


2021-09-08 10:47 
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Cambiar de interfaz 
grátata a 
comandos 
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Ahora supongamos que usas el 
entorno de escritorio Gnome. No es 
algo común, pero puede suceder 
que en un momento dado el sistema 
Gnome se queda congelado y no 
hay nada que hacer. Bueno, TTY es 
la solución a tu problema. 


dl 


ínea de 


dá EE Pulsas la combinación de teclas Ctrl 
+ Alt + F2 (tecla de función), automáticamente se abre 
la línea de comandos que como podrás comprobar es 
diferente a tu emulador de terminal. Si es necesario 
inserta tu nombre de usuario y contraseña. 


En nuestro ejemplo de uso queremos reiniciar Gnome, 
por tanto deberás ejecutar el siguiente comando. 


sudo killall gnome-shell 


Una vez ejecutado el comando, pulsas la combinación 
de teclas Ctrl + Alt + F7 (tecla de función) para retornar 
a la interfaz gráfica de Gnome. Problema solucionado. 
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on tty2 
4.0-051400- 


can be applied immediately. 
stack (HWE) is supported until April 2023. 


Killall -1 gnome-shell 


Otro caso realmente interesante. El otro día estaba 
probando VirtualBox en un equipo bastante antiguo, 
claro... pasó lo que tenía que pasar. El consumo de la 
cpu aumento desmesuradamente, hasta proporciones de 
volver al sistema totalmente inútil a mis consultas. 


La solución es similar a la anterior, pulsando la 
combinación de teclas Ctrl + Alt + F2 (tecla de función) 
accedí a la línea de comandos. Una vez en ella ejecuto 
la herramienta htop, para identificar el PID. 


571.7 6.1 0:54.24 


1568 sergio 


Una vez identificado en número PID (1535), la solución 
resulto tan simple como ejecutar el siguiente comando. 


sudo kill -1 1535 


Pulsando la combinación de teclas Ctrl + Alt + F7 (tecla 
de función), retornamos a nuestro entorno de escritorio 
con el problema solucionado. 
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Conectar un ¡iPhone como unidad externa 


en Ubuntu 20.04 


Hasta no hace mucho tiempo, conectar un iPhone como 
unidad externa en Ubuntu era una tarea complicada. El 
soporte que ofrecía Linux para los dispositivos ¡OS, 
como por ejemplo el iPhone, ¡Pad e iPod, no fue de los 
mejores. Situación lógica, dado el trato con el que 
maneja sus controladores privativos. 


Por suerte la situación ha cambiado, y hoy en día si es 
posible. En este artículo de hoy, vemos como montar el 
almacenamiento de tu iPhone (iPad, etc...) en Ubuntu, 
Linux Mint y derivados, de forma que se detecte como 
un nuevo dispositivo de almacenamiento externo. 


á 
Conectar un ¡iPhone como 
unidad externa en Ubuntu 20.04 


Para que el iPhone y otros dispositivos ¡OS sean 
reconocidos en Ubuntu, es necesaria la instalación de la 
biblioteca libimobiledevice. Debido a las medidas de 
seguridad de Apple, la librería Libimobiledevice es la 
única forma de obtener acceso a la información del 
dispositivo externo, así como a su almacenamiento 
interno. 


Comenzamos instalando las librerías. Si tienes una 
versión actualizada, es posible que ya la tengas, aun 
siendo así también son necesarias sus utilidades. 


sudo apt install libimobiledevice6 libimobiledevice-utils 


sergiofdemo-sololinux:"$ sudo sudo apt install 
libimobiledevice6 libimobiledevice-utils 
[sudo] contraseña para sergio: 

Leyendo lista de paquetes... Hecho 

Creando árbol de dependencias 


Leyendo la información de estado... Hecho 


libimobiledevice6 ya está en su versión más reciente 


(1.2.1-=git20191129.9f79242-1build1). 

fijado libimobiledevice6 como instalado manualmente. 

Se instalarán los siguientes paquetes NUEVOS: 
libimobiledevice-utils 

0 actualizados, 1 nuevos se instalarán, 0 para eliminar y 0 

no actualizados. 

Se necesita descargar 88,1 kB de archivos. 

Se utilizarán 509 kB de espacio de disco adicional después 

de esta operación. 

¿Desea continuar? [S/n] 


Una vez que hayas instalado las librerías, conecta 

tu iPhone al sistema. Si el sistema de archivos del 
iPhone no se monta automáticamente, deberás 
emparejar el dispositivo iPhone con Ubuntu. Ejecuta lo 
siguiente en la terminal. 


idevicepair pair 


Si todo es correcto recibirás un mensaje de éxito, pero 
aún debes permitir las múltiples conexiones entre el 
dispositivo y la instalación de Ubuntu. Para lograr tu 


objetivo, ejecuta el siguiente comando. 


Si por el contrario es imposible emparejar, y recibes error 
de dispositivo no encontrado como el de la siguiente 
imagen; mejor nos decantamos por la instalación 

de iFuse. 


$ 


:-$ idevicepair pair 


No device found, is it plugged in? 
=$ 


El paquete ¡Fuse también instala la 

librería Libimobiledevice, y como en el caso anterior 
permite montar un ¡Phone y que acceda al sistema de 
archivos Linux, entre otras cosas. lFuse viene incluido 
en los repositorios oficiales de Ubuntu, por tanto su 
instalación es bastante simple. 


sudo apt install ifuse 


sergiofdemo-sololinux:“$ sudo apt install ifuse 
Leyendo lista de paquetes... Hecho 
Creando árbol de dependencias 
Leyendo la información de estado... Hecho 
Se instalarán los siguientes paquetes NUEVOS: 

ifuse 
O actualizados, 1 nuevos se instalarán, 0 para eliminar y 0 
no actualizados. 
Se necesita descargar 15,7 kB de archivos. 
Se utilizarán 48,1 kB de espacio de disco adicional después 
de esta operación. 
Des:1 http://es.archive.ubuntu.com/ubuntu focal/universe 
amd64 ifuse amd64 1.1.4wgit20181007.3b00243-1 [15,7 kB] 
Descargados 15,7 kB en 1s (22,0 kB/s) 
Seleccionando el paquete ifuse previamente no seleccionado. 
(Leyendo la base de datos ... 165245 ficheros o directorios 
instalados actualmente.) 
Preparando para desempaquetar 
.../ifuse_1.1.4vgit20181007.3b00243-1_amd64.deb ... 
Desempaquetando ifuse (1.1.4-git20181007.3b00243-1) 
Configurando ifuse (1.1.4-git20181007.3b00243-1) 
Procesando disparadores para man-db (2.9.1-1) 


Progreso: [ 80%] 
AHI ARA A RARA ARA ROAD A RARA ARRASTRE 
HARO RARA AH 


Una vez que hayas instalado las librerías, conecta 

tu iPhone al sistema. Si el sistema de archivos del 
¡Phone no se monta automáticamente, deberás 
emparejar el dispositivo iPhone con Ubuntu. Ejecuta lo 
siguiente en la terminal. 


idevicepair pair 
usbmuxd -f -v 


Contalns music and photos 


PublicStaging 


WwWwW:Ssololinúxtes 


HARDWARE 


En el extraño caso de que iFuse también de problemas, reinicia el sistema con el dispositivo conectado, creas su 
directorio manualmente y de igual forma lo montas. 


sudo reboot 


sudo mkdir /media/iphone 
ifuse /media/iphone 


Una vez montado, deberías poder ver el sistema de archivos como de cualquier otro dispositivo. Copiar, cortar, pegar, 
agregar, modificar, y mucho más. 


Recuerda que de la misma forma que has montado la unidad manualmente, también lo puedes desmontar de manera 
segura ejecutando este comando en tu consola / terminal. 


ifuse -u /media/iphone 


WwWwW:sololinúuxies 
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Canales de Telegram: 
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Un entorno virtual Python es un 
directorio que contiene la instalación 
completa de una versión de Python, 
en el cual se incluyen varios 
paquetes específicos así como 
todos los módulos adicionales que 
resulten necesarios. 


Se permite crear varios entornos, de 
forma que nos permita tener un 
número ilimitado de versiones y 
módulos de Python diferentes. 
Todo esto independientemente de la 
versión principal de Python 
instalada en el sistema. Su utilidad 
es grandiosa, sobre todo para 
desarrolladores, ya que permite 
instalar aplicaciones que requieren 
de diferentes versiones y módulos 
de Python, como por ejemplo... 
doo, Django o Flask. 


La instalación y puesta en marcha 
del entorno virtual, es un proceso 
bastante rápido y sencillo que te 
tomara como mucho 10 minutos. En 
el artículo de hoy vemos lo sencillo 
que es crear, lo que también se 
conoce como Python virtual 
environment. 


2) python 


virtualenv 


Crear un entorno 
virtual Python en 
Ubuntu 20.04 


Como es habitual, lo primero que 
hacemos es actualizar nuestro 
sistema. 


sudo apt update 
sudo apt upgrade 


Ahora verificamos la versión actual de Python, instalada en nuestro sistema. 
python3 -V 


sergiofdemo-sololinux:"$ python3 -V 
Python 3.8.10 
sergiofdemo-sololinux: "$ 


Para crear nuestro entorno necesitamos el paquete python3-venv, este 
paquete instalará el módulo venv junto con algunas dependencias 
necesarias. Recuerda que puedes usar cualquier versión Python que quieras, 
pero que esté disponible en el repositorio de Ubuntu. 


sudo apt -y install python3-venv 


sergiofdemo-sololinux:"$ sudo apt -y install python3-venv 
Leyendo lista de paquetes... Hecho 
Creando árbol de dependencias 
Leyendo la información de estado... Hecho 
Se instalarán los siguientes paquetes adicionales: 
python-pip-whl python3-distutils python3-1lib2to3 python3.8-venv 
Se instalarán los siguientes paquetes NUEVOS: 
python-pip-whl python3-distutils python3-1lib2to3 python3-venv python3.8-venv 
0 actualizados, 5 nuevos se instalarán, 0 para eliminar y 0 no actualizados. 
Se necesita descargar 2.030 kB de archivos. 
Se utilizarán 4.465 kB de espacio de disco adicional después de esta operación. 
Des:1 http://es.archive.ubuntu.com/ubuntu focal-updates/universe amd64 python- 
pip-whl all 20.0.2-5ubuntu1.6 [1.805 kB] 
Des:2 http://es.archive.ubuntu.com/ubuntu focal-updates/main amd64 python3- 
lib2to3 all 3.8.10-Oubuntul-20.04 [76,3 kB] 
Des:3 http://es.archive.ubuntu.com/ubuntu focal-updates/main amd64 python3- 
distutils all 3.8.10-0ubuntul-20.04 [141 kB] 
Des:4 http://es.archive.ubuntu.com/ubuntu focal-updates/universe amd64 python3.8- 
venv amd64 3.8.10-0ubuntul“20.04 [5.456 B] 
Des:5 http://es.archive.ubuntu.com/ubuntu focal/universe amd64 python3-venv amd64 
3.8.2-0ubuntu2 [1.228 B] 
Descargados 2.030 kB en 1s (2.443 kB/s) 
Seleccionando el paquete python-pip-whl previamente no seleccionado. 
(Leyendo la base de datos ... 165252 ficheros o directorios instalados actualmen 
te.) 
Preparando para desempaquetar .../python-pip-whl_20.0.2-5ubuntu1.6_all.deb ... 
Desempaquetando python-pip-whl (20.0.2-5ubuntu1.6) ... 
Seleccionando el paquete python3-lib2to3 previamente no seleccionado. 
Preparando para desempaquetar .../python3-lib2to3_3.8.10-O0ubuntul=20.04_all.deb 


Desempaquetando python3-1lib2to3 (3.8.10-O0ubuntul=20.04) 
Seleccionando el paquete python3-distutils previamente no seleccionado. 


Preparando para desempaquetar 
Di sas 

Desempaquetando python3-distutils (3.8.10-O0ubuntul=20.04) 

Seleccionando el paquete python3.8-venv previamente no seleccionado. 

Preparando para desempaquetar .../python3.8-venv_3.8.10-Oubuntul=20.04_amd64.deb 


. ../python3-distutils_3.8.10-Oubuntul=20.04_all.de 


Desempaquetando python3.8-venv (3.8.10-Oubuntul=20.04) ... 
Seleccionando el paquete python3-venv previamente no seleccionado. 
Preparando para desempaquetar .../python3-venv_3.8.2-0ubuntu2_amd64.deb ... 
Desempaquetando python3-venv (3.8.2-Oubuntu2) 

Configurando python-pip-whl (20.0.2-5ubuntu1.6) ... 

Configurando python3-lib2to3 (3.8.10-Oubuntul=20.04) ... 
Configurando python3-distutils (3.8.10-Oubuntul=20.04) ... 
Configurando python3.8-venv (3.8.10-Oubuntul=20.04) 

Configurando python3-venv (3.8.2-Qubuntu2) ... 

Procesando disparadores para man-db (2.9.1-1) 
sergiofdemo-sololinux: "$ 


window = Toplevel() 


window.title( 
window.geometry ( 


f.define_grid(window, 10 


entry = db.return_entry(title) [0] 


Para crear nuestro primer entorno virtual de Python, inserta un nuevo 
directorio de trabajo que se creara de forma automática. En nuestro caso, 
hemos elegido... «my_python». Ejecuta el siguiente comando. 


SOLOLIN 


sudo python3 -m venv /opt/my_python 


Verifica que se han generado los archivos necesarios. 


ls /opt/my_python 


La carpeta debe incluir estos archivos... 


$ 
:-$ ls /opt/my python 


bin include lib 1lib64 pyvenv.cfg share 
$ 


Bien, solo falta habilitar el entorno, para ello accedemos al directorio y lo activamos. No olvide cambiar «my-python», 
por el nombre que tú hayas elegido. 


sudo su 
cd /opt/ 
source my_python/bin/activate 


Automáticamente accedemos al nuevo entorno, observa que su nombre aparece al principio de cada línea de nuestra 
terminal / consola. 


sergiofdemo-sololinux:“$ sudo su 

[sudo] contraseña para sergio: 
rootedemo-sololinux:/home/sergio* cd /opt/ 
rootedemo-sololinux:/opt+* source my_python/bin/activate 
(my_python) rootedemo-sololinux:/opt+ 


Una vez habilitado, ya puedes comenzar a trabajar en el nuestro proyecto. También puedes instalar y usar cualquier 
aplicación Python, incluyendo nuevos módulos. En el ejemplo instalamos el módulo IDNA, que ofrece soporte para el 
protocolo de nombres de dominio internacionalizados en aplicaciones (IDNA), como se especifica en a 


pip install idna 


(my_python) rootedemo-sololinux:“* pip install idna 
Collecting idna 
Downloading idna-3.2-py3-none-any.whl (59 kB) 
| 59 kB 985 kB/s 
Installing collected packages: ¡idna 
Successfully installed idna-3.2 


:-$ sudo su 
[sudo] contraseña para sergio: 
rootfademo-sololinux:/home/sergio* cd /opt/ 
rootademo-sololinux:/opt+* source my python/bin/activate 
(my python) rootfademo-sololinux:/opt* cd 
(my python) rootfdemo-sololinux:-—+ 
(my python) rootademo-sololinux:-+* pip install idna 
ollecting idna 

Downloading idna-3.2-py3-none-any.whl (59 kB) 
¡IE | ss ks 9s5 k8/s 

Installing collected packages: idna 
Successfully installed idna-3.2 
(my python) rootfedemo-sololinux:-+ 


Para deshabilitar temporalmente el entorno de trabajo virtual (sin borrarlo), ejecuta... 


deactivate 


Opera tal como en el ejemplo, para no tener problemas. 


(my_python) rootedemo-sololinux:“* deactivate 


rooteademo-sololinux: + 
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NOTICIAS 


Manjaro abandona Mozilla Firefox 


Esto se veía venir, y después de que varias distribuciones linux con poca repercusión entre los usuarios Linux, se 
atrevieran a quitar el navegador web por excelencia de la comunidad Linux. Llega Manjaro y hace lo mismo, aunque 
debemos puntualizar que de momento parece una toma de contacto, pues a modo de primera experiencia se incluye 
Vivaldi como navegador web predeterminado, tan solo en la nueva versión Manjaro Cinnamon 21.1.2. 


La noticia fue recibida por los desarrolladores de Vivaldi, en medio de una gran algarabía. Es la primera vez que la 
versión completa de una de las distribuciones más importantes, dejaba fuera a Mozilla Firefox. Esta vez solo ha 
sido Cinnamon, pero ya verás como tan solo es la primera ficha del dominó que ha caído, vendrán más. Aquí el 
comunicado traducido del equipo Vivaldi. 


¡Hoy tenemos una gran noticia!. Estamos orgullosos de compartir con vosotros que Vivaldi es ahora el navegador predeterminado de la 
distribución Linux basada en Arch, Manjaro en su edición Cinnamon que ahora ofrece una experiencia de navegación rápida, confiable y rica en 
funciones. 


Cinnamon, una de las ediciones más populares de Manjaro, pues es un entorno de escritorio que funciona sin ningún problema con las nuevas 
funciones y la filosofía de diseño que identifica a Vivaldi. 


La popular distribución Linux Manjaro se basa en Arch Linux, un sistema de lanzamiento continuo, rápido y personalizable (rolling). Manjaro ha 
introducido una capa de estabilidad, con la capacidad de manejar las actualizaciones de paquetes con un proceso de evaluación y corrección de 
errores. Posee herramientas dedicadas que simplifican enormemente la instalación, el manejo de hardware y la administración de paquetes, 
actualizaciones y copias de seguridad. Esto hace que Manjaro sea muy fácil de usar, ahora con Vivaldi aún más. 


“4 
a 


Manjaro abandona Mozilla 
Firefox 


En este artículo no vamos a discutir las características 
de Vivaldi, pero si es cierto que tomo la base 

de Cromium y la mejoro, además de manera Se ARI Ass 
considerable. Por otro lado tenemos a Firefox, que le Bloqueador de anuncios y 
duela a quien le duela tiene un comportamiento y una e 
forma de operar lenta y tosca. 
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Barra de estado Barra de estado 


€ de Avance rápido / Rebobinado Avance rápido / Rebobinado 
En realidad pienso que las enormes contribuciones a la Correo 
comunidad, por parte de la Fundación Mozilla han ia pa a 
mantenido a Firefox al pie del cañón. Hoy en día esto ya 
es inadmisible, Mozilla Firefox funcionaba muy bien en monopestañas y con múltiples sesiones. Esto ya no basta para 
estar a la altura de los grandes navegadores, Gecko se ha quedado atrás y, no vemos grandes esperanzas de 
mejorar su desarrollo a no ser que cambien o desarrollen un nuevo motor. 

En la siguiente imagen de ejemplo, podemos observar que ya no existe Firefox. El navegador web 

predeterminado es Vivaldi. 


Feeds 


Ejemplo de uso del navegador web Vivaldi, en Manjaro Cinnamon. 
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Qué es el instalador calamares en Linux 


Calamares es una utilidad de instalación para Elección del kernel, entornos de trabajo, herramientas 
distribuciones GNU / Linux. Es liviano, fácil de usar, de comunicación, multimedia, emuladores de terminal, 
pragmático, y funciona en la mayoría de distribuciones gestores de archivos, etc. Todo depende del 

Linux modernas. Permite una configuración flexible y desarrollador, fabrica un instalador a tu gusto. 
personalizada, a la hora de instalar tu sistema operativo Este instalador es totalmente gráfico, y se usa 

linux sin tener que interactuar directamente con la línea especialmente cuando se instala Linux desde una Live; 


de comandos. 
Es decir haciendo clic en el icono del escritorio. Como no 


Calamares es un ejemplo vivo de la filosofía del proyecto podía ser menos, admite multitud de idiomas, además 


GNU, pues los desarrolladores de diversas y opuestas de ofrecer la opción de configurarlo en la primera 
distribuciones Linux, decidieron unir sus esfuerzos para pantalla del instalador. 
crear un instalador conjunto que fuera eficiente, rápido y Zona horaria del sistema, marcar tu ciudad específica en 
totalmente configurable. el mapa, crear tablas de partición, discos de partición / 
SSD por megabyte, para cada sección, etiquetas, FS, 
Si bien es cierto que su comunidad de desarrolladores claves y, mucho más. Una vez configurado con tus datos 
ha crecido, en sus comienzos fue un producto casi y personalizaciones, aparece la hora de resumen de la 
exclusivo para KDE. El motivo es evidente, los primeros instalación, pulsas en aceptar y listo. Calamares es muy 
en participar fueron en exclusiva, desarrolladores de fácil de usar. 
KDE que aportaron sus contribuciones desde: 
BBQLinux, Fedora, KaOS, Kubuntu, Manjaro, Maui, Vemos algunas imágenes de ejemplo. 
Netrunner y OpenMandriva. Hoy en día es utilizado por GeckoLinux STATICKFCE Instalador HE 
muchas distribuciones, algunas tan conocidas como 
Debian dd es MLITTTLETETTIT 7 
Bienvenido 
GeckoLinux STATIC XFCE Instalador *.. -0X Ubicación 080 E 0 E E 
Bienvenido al instalador de Calamares para GeckoLinux SSTidones II 
STATIC XFCE 153.x. usuarios 
Ubicación El programa le preguntará algunas cuestiones y configurará GeckoLinux STATIC XFCE en su Portuguese (Brazil) +] [Asturian (Spain, with bottom-dot H and bottom-dot L) 
edad denador. Resumen Rosso Catalan (Spain, with middle-dot L) 
57 si Ea Instalar Serbian Spanish (Dvorak) 
Particiones A a, ¿Latviski MS Sinhala (phonetic) Spanish (Macintosh) 
Usuarios 4 pa a, Eme Portugués pala a Remi EE 


Spanish (no dead keys) 


Esperanto 
Deutsch do oGalego Via Miel Slovehscina 
Norsk: El mi Snanish (Latin American) +) Spanish (with Sun dead kevs) 


ina. EMyvixá Túrkge 
Cestind Suriamu Wolof 


Romána pol 


Resumen 


Instalar 


Finalizar 
a] español de España 


D Acercade [Bl GeckoLinux ayuda — [XK] Notas de publicación 


Www:sololinúxies atrás || siguiente Cancelar 


GeckoLinux STATIC XFCE Instalador $ De 


Nombre 


sergio o 


WwWw:sololinúuxtes c 3 siguiente Cancelar 


¿Qué nombre desea usar para ingresar? 


Bienvenido 
e o 
Es E Ubicació 
Qué es el instalador calamares A o 
Ñ : Elija una contraseña para mantener su cuenta segura. 
en Linux EeCic00S ee o 
Y ¡Conectarse automaticamente sin pedir la contraseña. 
SST sar la misma contraseña para la cuenta de administrador. 
La mayor parte del código de la herramienta, está escrita O A E 
en C++ 17, usando Qt 5.9 + como interfaz de usuario. Finalizar 


Ofrece un diseño modular y Python 3 es su principal 
lenguaje de programación. La interfaz de Python 3 se 


implanta con Boost Python, y toda la configuración de daa ][mbsiguiente | [cancelar 


Calamares se realiza en YAML. Tienes a tu disposición 
muchísimos módulos listos para usar, aunque se permite 


crear los tuyos propios. E 
is a BTOD Puedes descargar Calamares y sus módulos desde su 


PO ; repositorio oficial. 
Debes saber que si tienes planeado crear tu propia P 


distro, tienes la opción de modificar la apariencia del + Descargar Calamares 

instalador, incluir ilustraciones y explicaciones del los + Descargar módulos de Calamares 
pasos a seguir, el progreso, maximizar, etc. Todo ello 

añadiendo módulos, por ejemplo... en la distro Arco 

Linux tenemos un módulo que nos llama la atención, ya 

que aparece una pantalla en la cual puedes elegir el 

Kernel a instalar. 
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ust 


Rust es un lenguaje de programación de código 
abierto, centrado en la velocidad, la seguridad y el 
paralelismo. Este lenguaje es ampliamente utilizado por 
los desarrolladores, para crear una amplia gama de 
software como por ejemplo: motores de juegos, sistemas 
operativos, sistemas de archivos, componentes para un 
navegador y motores de simulación para realidad virtual. 


Si lo analizamos sintácticamente vemos que es muy 
similar a C ++, pero con la gran diferencia 

que Rust puede garantizar la seguridad de la memoria 
mediante el uso de un verificador que valida sus 
referencias. En el artículo de hoy vemos como instalar 
este impresionante lenguaje, en Debian 11 Bullseye y 
todos sus derivados. 


Instalar Rust en Debian 11 
Bullseye 


Antes de comenzar, actualizamos nuestro sistema. 


sudo apt update 44 sudo apt upgrade 


Ahora las dependencias requeridas por Rust. 


sudo apt install curl build-essential gcc make -y 


up libalgorithm-merge-perl (0.08-3) ... 
g up 2.1-6) ... www.sololinux.es 
up 1 
ing up ee 
up libgcc-10-dev:amd64 (10.2.1-6) ... 
up libgd3:amd64 (2.3.0-2) ... 
up cpp (4:10.2.1-1) ... 
up libc6-dev:amd64 (2.31-13) ... 
up libc-devtools (2.31-13) ... 
up binutils-x86-64-linux-gnu (2.35.2-2) ... 
up libstdc++-10-dev:amd64 (10.2.1-6) .. 
up binutils (2.35.2-2) ... 
up dpkg-dev (1.20.9) ... 
up gcc-10 (10.2.1-6) ... 
ing up g++-10 (10.2.1 
up 2 
up 8 0 AA 
update-alternatives: using /usr/bin/g++ to provide /usr/bin/c++ (c++) in auto mol 
de 
Setting up build-essential (12.9) ... 
Processing triggers for libc-bin (2.31-13) ... 
Processing triggers for man-db (2.9.4-2) ... 


AAA IRALA.) 


Una vez que haya completado la instalación requerida 
de paquetes, usamos la herramienta curl para 
descargar el script de instalación de Rust. 


f https://sh.rustup.rs | 


Como puedes ver en el siguiente ejemplo, debes 
pulsar «1» para realizar una instalación estándar. 


rootesololinux-demo:“* curl --proto '=https' --tlsv1.2 -sSf 
https://sh.rustup.rs | sh 
info: downloading installer 
Welcome to Rust! 
This will download and install the official compiler for the 
Rust 
programming language, and its package manager, Cargo. 
Rustup metadata and toolchains will be installed into the 
Rustup 
home directory, located at: 

/root/.rustup 
This can be modified with the RUSTUP_HOME environment 
variable. 
The Cargo home directory located at: 

/root/.cargo 
This can be modified with the CARGO_HOME environment 
variable. 
The cargo, rustc, rustup and other commands will be added to 
Cargo's bin directory, located at: 

/root/.cargo/bin 
This path will then be added to your PATH environment 
variable by 
modifying the profile files located at: 

/root/.profile 

/root/.bashrc 
You can uninstall at any time with rustup self uninstall and 
these changes will be reverted. 
Current installation options: 

default host triple: x86_64-unknown-linux-gnu 
default toolchain: stable (default) 
profile: default 

modify PATH variable: yes 
1) Proceed with installation (default) 
2) Customize installation 
3) Cancel installation 
> L 


La instalación es rápida. 


1) Proceed with installation (default) 
2) Customize installation 
3) Cancel installation 
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: profile set to 'default' 

: default host triple is x86_64-unknown-linux-gnu 

: syncing channel updates for 'stable-x86_64-unknown-linux-gnu' 

: latest update on 2021-09-09, rust version 1.55.0 (c8dfcfe04 2021-09-06) 
: downloading component 'cargo' 

: downloading component 'clippy' 

: downloading component 'rust-docs' 

: downloading component 'rust-std' 

: downloading component 'rustc' 

: downloading component 'rustfmt' 


: installing component 'cargo' 
: installing component 'clippy' 
: installing component 'rust-docs' 


MiB / 17.0 MiB (100 %) 5.6 MiB/s in 2s ETA: 
: installing component 'rust-std' 

MiB / 22.3 MiB (100 %) 12.7 MiB/s in 
: installing component 'rustc' 

MiB / 51.0 MiB (100 %) 13.9 MiB/s in 
: installing component 'rustfmt' 
: default toolchain set to 'stable-x86_64-unknown-linux-gnu' 


1s ETA: 
3s ETA: 
- rustc 1.55.0 (c8dfcfe04 2021-09-06) 


Rust is installed now. Great! 


Antes de utilizar Rust, debes habilitar su entorno en la 
shell actual. 


source «/.profile 
source «=/.cargo/env 


SOLOLIN 


MANUALES 


Puedes buscar actualizaciones periódicamente con el siguiente comando. 


rustup update 


Ejemplo... 


rootesololinux-demo:“* rustup update 
info: syncing channel updates for 'stable-x86_64-unknown-linux-gnu' 
info: checking for self-updates 
stable-x86_64-unknown-linux-gnu unchanged - rustc 1.55.0 (c8dfcfe04 2021-09-06) 
info: cleaning up downloads € tmp directories 
rootasololinux-demo : ft 


Si por algún motivo, quieres desinstalar Rust... 


rustup self uninstall 


SOLOLINUX 25 


DISTROS LINUX 


Kali Linux 2021.3 - Listo para su descarga 


Kali Linux 2021.3 es una 
distribución Linux basada en 
Debian, que viene con una 
tremenda colección de herramientas 
forenses y de seguridad. Siendo 
uno de los proyectos pentest más 
activos, cada año nos presentan 4 
versiones para que siempre 
estemos a la última. Hace apenas 
unas horas, han lanzado la tercera 
versión de este año en curso 2021. 
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Como es habitual viene con muchas 
actualizaciones y grandes mejoras, 
entre las cuales debemos destacar “ll. . d y 4 PS 
el nuevo OpenSSL que se ha | A | | j IMUX J) 09 | 5 
configurado para una compatibilidad ZA 6 y ES Lay .a 
más amplia. Esto permite el uso de 

protocolos heredados, lo que quiere 

decir que se permite la comunicación con sistemas más antiguos que los usados en la actualidad. Esta novedad es 
importante, ya que nos permite buscar superficies de ataque adicionales generadas por aplicaciones obsoletas, 
normalmente olvidadas por el usuario. 


Kali Linux 2021.3 - Listo para su descarga 


El uso de Kali (modo live) en entornos de virtualización (VMware, VirtualBox, Hyper-V y QEMU + Spice), se ha 
simplificado con una nueva configuración de Kali, en el modo de sesión mejorado de Hyper-V. 


Los desarrolladores también lanzaron la primera versión de Kali NetHunter para un reloj inteligente: el TicHunter 
Pro (con Wear OS). Esto aún está en versión experimental, por tanto, sus características se limitan a ataques USB y 
algunas funciones básicas. Las mejoras futuras previstas incluyen soporte para Nexmon y, el uso interno de Bluetooth. 


Kali Linux 2021.3 también viene con una serie de nuevas herramientas, realmente interesantes: 
+  Berate_ap — Orquestar puntos de acceso Wi-Fi no autorizados. 

+ CALDERA - Plataforma de emulación automatizada. 

+  EAPHammer — Ataques dirigidos contra redes Wi-Fi WPA2-Enterprise. 

* —HostHunter — Identificar y descubrir nombres de host usando técnicas OSINT. 

+  —RouterKeygenPC — Generador de claves Wi-Fi WPA / WEP predeterminadas. 

+  Subjack -— Adquisición de subdominios. 

+ WPA_Sycophant - Cliente para ataque de retransmisión EAP. 


Los desarrolladores también han mejorado el soporte de imágenes de Kali ARM. El nuevo sitio >KALI Tools ha 


mejorado considerablemente respecto a su antecesor. Por otro lado, la nueva distribución Linux KALI también ha 
recibido mejoras interesantes a nivel visual, en su escritorio por defecto. 


Puedes descargar Kali Linux 2021.3, desde su página oficial. 


+ Descargar Kali Linux 2021.3 
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También nos resultarán necesarias algunas 
ES dependencias, que procedemos a instalar 


pS 


> inmediatamente. 


php 5 


sudo apt-get install ca-certificates apt-transport-https 


software-properties-common -y 


sudo apt install apt-transport-https lsb-release ca- 
certificates 


Agregar repositorio PHP 8 


Antes de agregar el nuevo debemos importar e instalar 
la clave GPG. 


sudo wget -0 /etc/apt/trusted.gpg.d/php.gpg 
https://packages.sury.org/php/apt.gpg 


debian Jl 1 


PHP es uno de los lenguajes de programación del lado 
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. z .q. . . rootésololinux '"p.gpg https://packages.sury.org/php/apt.gpg 

de servidor, más populares y utilizados a nivel mundial. cc2821.99-15 16:12:24-> https://peckages sury org A 
Según estadísticas oficiales, PHP está implantado en IN 
este año 2021 en el 79,1% de los sitios web más pr AA 
conocidos a nivel mundial. La serie 7.x sigue siendo la O O 
reina, con una cuota de mercado del 65,6%. Algo lógico, — MEMES Mao Ia Ances 
pues la mayoría de CMS y frameworks, como Ahora el repositorio. 
WordPress, Magento o Laravel, involucran el uso de lo EH ZE echo uelnepes palas cu oro lolo E 
PHP. (lsb_release -sc) main" > /etc/apt/sources.list.d/php.list' 
La última versión de PHP es la serie 8, que supone una rootesololinux-demo : «+ , 

S a a rootasololinux-demo:“* sudo sh -c 'echo "deb 
actualización importante del lenguaje PHP. Nuevas y https: //packages.sury.org/php/ $(Lsb_release -sc) main" > 
potentes características y optimizaciones, incluyendo los /etc/apt/sources.list.d/php.list' 


rootasololinux-demo: 


argumentos con nombre, tipos de unión, atributos, 
propiedades del constructor, expresiones de 


coincidencia, operador seguro null, JIT, mejoras en el Instalar PHP 8 

sistema de tipos, además de un excelente manejo de 

errores y coherencias. En Apache 

En el artículo de hoy veremos como instalar PHP 8.x, Para instalar PHP 8 como un módulo de Apache, ingresa 
en Debian 11 Bullseye y sus derivados. Trataremos las el siguiente comando. 


tres OPrIenEES habituales. sudo apt update $6 sudo apt install php8.0 libapache2-mod- 
1. En módulo Apache php8.0 


2. En módulo Apache con FPM pa 7 
- Solo falta reiniciar el servicio, para que cargue el nuevo 
3. En Nginx módulo. 


sudo systemctl restart apache2 


rootesololinux-demo:-“* sudo apt update 88 sudo apt install php8.0 libapache2-mod- 

php8.0 

Hit:1 http://security.debian.org/debian-security bullseye-security InRelease 

Hit:2 http://ftp.debian.org/debian bullseye InRelease 

Hit:3 http://ftp.debian.org/debian bullseye-updates InRelease 

Get:4 https://packages.sury.org/php bullseye InRelease [6841 B] 

Get:5 https://packages.sury.org/php bullseye/main amd64 Packages [300 kB] 

Fetched 307 kB in 1s (598 kB/s) 

Reading package lists... Done 

Building dependency tree... Done 

Reading state information... Done 

a 3 packages can be upgraded. Run 'apt list --upgradable' to see them. 

Instalar php 8 en Debian 11 a 

Building dependency tree... Done 

Reading state information... Done 


Bullse e The following package was automatically installed and is no longer required: 
y bsdmainutils 


Use 'sudo apt autoremove' to remove it. 
The following additional packages will be installed: 
cla a apache2 apache2-bin apache2-data apache2-utils libapri libaprutil1 
Requisitos previos libaprutil1-dbd-sqlite3 libaprutil1-1ldap libjansson4 liblua5.3-0 libsodium23 
php-common php8.0-cli php8.0-common php8.0-opcache php8.0-readline 
Suggested packages: 
ñ A le apache2-doc apache2-suexec-pristine | apache2-suexec-custom www-browser 
Como es habitual, comenzamos actualizando el sistema. php-pear 
The following NEW packages will be installed: 
apache2 apache2-bin apache2-data apache2-utils libapache2-mod-php8.0 libapri 
libaprutil1 libaprutil1-dbd-sqlite3 libaprutili-ldap libjansson4 liblua5.3-0 
libsodium23 php-common php8.0 php8.0-cli php8.0-common php8.0-opcache 
php8.0-readline 
O upgraded, 18 newly installed, O to remove and 3 not upgraded. 
Need to get 6678 kB of archives. 
After this operation, 28.5 MB of additional disk space will be used. 
Do you want to continue? [Y/n] 
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sudo apt update $4 sudo apt full-upgrade -y 


En Apache con FPM 1: Si obtienes algún error al instalar PHP 8 en 
Apache, es porque no lo tienes totalmente instalado. Lo 


Para instalar PHP-FPM para Apache 2, debes aplicar los puedes solucionar ejecutando este comando. 
e eonnada Pab Ep Mino esa Henledo. 
predeterminada, PHP-FPM no está habilitado en 


rootGsololinux + apt install apache2 


Apache. Sigue todos los pasos que te indico, no tendrás — MARA 
Reading state informatio, 


ningún problema. me E pa will be installed: 


stine | apache2-suexec-custom www-browser 
l be installed: 


sudo apt update $4 sudo apt install php8.0-fpm libapache2- 
mod-fcgid 


remove and 3 not upgraded 
Need to get 678 k 
After this ope 
[Do you w 
(Get:1 http y security/main amd64 apache2-data all 2.4.48-3.1+debllul [160 kB] 
security/main amd64 apache2-utils amd64 2.4.48-3.1+debllul [252 kB] 
curity bullseye-security/main amd64 apache2 amd64 2.4.48-3.1+debllul [266 kB] 


additional disk space will be used 


sudo a2enmod proxy_fcgi setenvif 8 sudo a2enconf php8.0-fpm 


sudo systemctl restart apache2 


Verificamos su estado. 


sudo systemctl status php8.0-fpm 
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F-8 
are supported and installed on your system. 


rootéGsololinux-demo:-4+ sudo systemctl status php8.0-fpm 

vice - The PHP 8.0 FastCGI Process Manager 

oaded (/lib/systemd/system/php8.0-fpm.service; enabled; vendor prB 

since Thu 2021-09-16 14:31:45 CEST; 8min ago 

an:php-fpm8.0(8) 

8193 (php-fpm8.0) 

"Processes active: 0, idle: 2, Requests: 0, slow: 0, Traffic: OregHg 
(limit: 4915) 

0.6M 

/system.slice/php8.0-fpm.service 

Easisa php-fpm: master process (/etc/php/8.0/fpm/php-fpm.conf) 
18194 php-fpm: pool www - 
18195 php-fpm: pool www www.sololinux.es 


Sep 16 14:31:45 sololinux-demo systemd[1]: Starting The PHP 8.0 FastCGI Process 
Sep 16 14:31:45 sololinux-demo systemd[1]: Started The PHP 8.0 FastCGI Process pg 


ines 1-15/15 (END) MENS 


En Nginx 


Nginx no ofrece soporte PHP de forma predeterminada, 
es necesario instalar PHP-FPM “administrador de 
procesos fastCGl” para manejar correctamente 
archivos PHP. 


sudo apt install php8.0-fpm php8.0-cli -y 


sudo systemctl status php8.0-fpm 


Resultado de la verificación del estado. 


rootesololinux-demo:=* sudo systemctl status php8.0-fpm 
e php8.0-fpm.service - The PHP 8.0 FastCGI Process Manager 
Loaded: loaded (/lib/systemd/system/php8.0-fpm.service; 
enabled; vendor preset: enabled) UL “dl 
Active: active (running) since Thu 2021-09-16 14:31:45 á << 
CEST; 19min ago 
Docs: man:php-fpm8.0(8) Canales de Telegram: 
Main PID: 18193 (php-fpm8.0) canal SoloLinu 
Status: "Processes active: 0, idle: 2, Requests: 0, 'lanal SoloWordpress 
slow: 0, Traffic: Oreq/sec" e 
Tasks: 3 (limit: 4915) “hat de S inux en Telearan 


Memory: 10.6M 
CGroup: /system.slice/php8.0-fpm.service 
18193 php-fpm: master process 
(/etc/php/8.0/fpm/php-fpm.conf) =— 


18194 php-fpm: pool www 

18195 php-fpm: pool www 
Sep 16 14:31:45 sololinux-demo systemd[1]: Starting The PHP (A) ($) (Y) 
8.0 FastCGI Process Manager... S Y) ==Y ==Y == 


Sep 16 14:31:45 sololinux-demo systemd[1]: Started The PHP 
8.0 FastCGlI Process Manager. : 5 : 
rootGsololinux-demo: + designed by 'Y freepik 


El comando chage se utiliza para 
ver o modificar una cuenta de 
usuario, además de información 
variada como la caducidad de la 
contraseña, incluyendo el cambio de 
la fecha y más. 


Ampliamente utilizado por los 
administradores de sistemas, en el 
artículo de hoy vemos sus formas 
de uso más comunes e 
interesantes. Incluyendo sus 
ejemplos prácticos que ayudan a 
una mejor comprensión. 


Uso del comando chage con ejemplos 


Antes de comenzar con los ejemplos de uso, debes tener presente que este comando requiere ser ejecutado por el 
root, o adquiriendo los permisos correspondientes escribiendo sudo antes del comando. La sintaxis es muy simple, 
Observa. 


sudo chage [opciones] usuario 


Las opciones más habituales, son... 


-d, --lastday ÚLTIMO_DÍA establece el día del último cambio de la 
contraseña a ÚLTIMO DÍA 

-E, --expiredate FECHA_CAD establece la fecha de caducidad a FECHA_CAD 

-h, --help muestra este mensaje de ayuda y termina 

-i, --1508601 use YYYY-MM-DD when printing dates 

-I, --inactive INACTIVA deshabilita la cuenta después de INACTIVA 
días de la fecha de caducidad 

-1, --list muestra la información de la edad de la cuenta 

-m, --mindays DÍAS_MIN establece el número mínimo de días antes de 
cambiar la contraseña a DÍAS_MIN 

-M, --maxdays MAX_DAYS set maximum number of days before password 
change to MAX_DAYS 

-R, --root CHROOT_DIR directory to chroot into 

-W, --warndays DÍAS _AVISO establece los días de aviso de expiración a 
DÍAS_AVISO 


Muestra información relativa a la antigiiedad de la cuenta 


La opción «-l», nos imprime los datos requeridos. 


sudo chage -1l sergio 


rootesololinux-demo:“* sudo chage -1l sergio 
Último cambio de contraseña :sep 14, 2021 
La contraseña caduca : nunca 

Contraseña inactiva : nunca 


La cuenta caduca : nunca 

Número de días mínimo entre cambio de contraseña : 0 

Número de días máximo entre cambio de contraseña : 99999 
Número de días de aviso antes de que caduque la contraseña : 7 
rootasololinux-demo : 


Modificar la fecha de modificación de contraseña rootesololinux-demo:=*k sudo chage -d 2022-12-01 sergio 
rootesololinux-demo: rt 
rootesololinux-demo:“* sudo chage -1l sergio 
23 A . Último cambio de contraseña ¿dic 01, 2022 <<< ejemplo 
En este caso, utiliza esta sintaxis. La contraseña caduca + NUNCA 


Contraseña inactiva : nunca 
La cuenta caduca : nunca 


Número de días mínimo entre cambio de contraseña : 0 

Número de días máximo entre cambio de contraseña : 99999 
Número de días de aviso antes de que caduque la contraseña : 7 
rootesololinux-demo: + 


sudo chage -d YYYY-MM-DD usuario 


SOLOLINI 


Establecer fecha de caducidad de una cuenta 


sudo chage -E YYYY-MM-DD usuario 


rootasololinux:-4+ sudo chage -E 2024-12-31 sergio 
rootasololinux:-+ 

rootasololinux:-4* sudo chage -1l sergio 

Último cambio de contraseña 

La contraseña caduca 

¡Contraseña inactiva 

La cuenta caduca 

Número de días mínimo entre cambio de contraseña 
Número de días máximo entre cambio de contraseña : 99999 
Número de días de aviso antes de que caduque la contraseña :7 
rootesololinux:-—+ 


2020 


: sep 02, 


¿ nunca 
¿ nunca 


: dic 31, 2024 
0 


Mínimo número de días entre cambios de contraseña 


Para no controlar el número de días entra cambios de 
password, puedes usar el valor 0. 


sudo chage -m NUM_DAYS usuario 


rootesololinux:“=* sudo chage -m O sergio 
rootesololinux: 

rootesololinux:“* sudo chage -1l sergio 

Último cambio de contraseña : sep 02, 2020 

La contraseña caduca : nunca 

Contraseña inactiva : nunca 

La cuenta caduca ¿dic 31, 2024 

Número de días mínimo entre cambio de contraseña : 0 
Número de días máximo entre cambio de contraseña : 99999 
Número de días de aviso antes de que caduque la contraseña : 
7 

rootesololinux: 


Máximo número de días entre cambios de 
contraseña 


Para no controlar el número de días entra cambios de 
password, puedes usar el valor 0. 


sudo chage -M NUM_DAYS usuario 


rootGsololinux:-* sudo chage -M O sergio 


-1 sergio 
: sep 02, 2020 
: sep 02, 2020 
: nunca 
dic 31, 
E) 


La contraseña caduca 
Contraseña inactiva 
2024 


máximo entre cambio de contraseña 0 
de aviso antes de que caduque la contraseña E 
+ 
A 
$ 


rootGsololinux: 
rootasololinux: 
rootasololinux: 


Días de advertencia, antes de que caduque la 
contraseña 


sudo chage -W NUM_DAYS usuario 


En el ejemplo, insertamos tres días. 


rootesololinux:“* sudo chage -W 3 sergio 

rootesololinux: 

rootesololinux:“* sudo chage -1l sergio 

Último cambio de contraseña : sep 02, 2020 

La contraseña caduca : sep 02, 2020 

Contraseña inactiva : nunca 

caduca ¿dic 31, 2024 

días mínimo entre cambio de contraseña : 0 

días máximo entre cambio de contraseña : 0 

días de aviso antes de que caduque la contraseña : 


La cuenta 
Número de 
Número de 
Número de 
E 

rootesololinux: + 


Uso de chage sin opciones 


Si quieres configurar todos los valores, lo más práctico 
es usar el comando sin opciones. El sistema nos 
pregunta todos los valores uno por uno. 


sudo chage [usuari 


rootGsololinux-demo:-* sudo chage sergio 


ambiando la información de la edad para sergio 


Introduzca el nuevo valor, o pulse INTRO para usar el valor predeterminado 


Duración mínima de la contraseña [0]: 5 

Duración máxima de la contraseña [99999]: 365 

Último cambio de contraseña (AAAA-MM-DD) [2022-12-01]: 

Aviso de caducidad de la contraseña [7]: 5 

Contraseña inactiva [-1]: 3 

Fecha de caducidad de la cuenta (AAAA-MM-DD) [-1]: O 
rootGsololinux-demo: 4 


2021-12-31 


Obtenemos este resultado. 


rootesololinux-demo:“* sudo chage -l sergio 

Último cambio de contraseña ¿dic 31, 2021 

La contraseña caduca ¿ dic 31, 2022 

Contraseña inactiva : ene 03, 2023 

La cuenta caduca : ene 01, 1970 

días mínimo entre cambio de contraseña : 5 

días máximo entre cambio de contraseña : 365 
días de aviso antes de que caduque la contraseña : 


Número de 
IS 
Número de 
5 

rootasololinux-demo : 


Canales de Telegram: 


designed by Y freepik 


Es posible que tu distribución no tenga la herramienta 
curl instalada por defecto, la instalas con este comando. 


sudo apt-get install -y curl 


rootésololinux-demo:-4 
rootésololinux-demo:-% sudo apt install -y curl 
Leyendo lista de paquetes... Hecho 
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Creando árbol de dependencias... Hecho 

Leyendo la información de estado... Hecho 

curl ya está en su versión más reciente (7.74.0-1.3+b1). 

O actualizados, O nuevos se instalarán, O para eliminar y O no actualizados. 
rootGsololinux-demo : —+t 


Bien, ahora dependiendo de tu versión Debian (11 / 10), 


i $ 
| importa la key publica y agrega el repositorio que 
; corresponda. 


Debian 11 
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En los últimos tiempos, estamos viviendo drásticos 


cambios en el mundo de los navegadores web para curl -fsSL https://deb.opera.com/archive.key | sudo gpg -- 

Linux y, otros sistemas operativos. Desde la decisión Jearmor 0: (USE Share/Keyrinas/ OperabromserSkeyT 010 -9Da 

de Chrome de bloquear la API a Chromium, con el único echo "deb [signed-by=/usr/share/keyrings/operabrowser- 

fin de entorpecer el correcto funcionamiento de los keyring.gpg] https://deb.opera.com/opera-stable/ stable non- 

clones del mismo Chromium, hasta la valiente iniciativa FORO > IERNÓOciER 7 EU OPE SGU ces est UVOpEra STaDheSMLSt 

de los desarrolladores de Manjaro Cinnamon al Debi 

SA g : ebian 10 

prescindir de Firefox, usando como alternativa 

el navegador Vivaldi. curl -fsSL https://deb.opera.com/archive.key | sudo apt-key 
add - 

Las imposiciones con tufillo a mafia, por parte de echo "deb https://deb.opera.com/opera-stable/ stable non- 

Canonical tampoco se quedan atrás. Todos recordáis el free" | sudo tee /etc/apt/sources.list.d/opera-stable.list 

revuelo que supuso la decisión, de forzar la instalación 

de Chromium mediante Snap. Pues ahora parece que Actualizamos de nuevo. 

vienen curvas otra vez, porque de nuevo Canonical con sudo apt-get update 

su producto estrella (Ubuntu), va a realizar la misma 

práctica pero con Mozilla Firefox. rootesololinux-demo:“* sudo apt-get update 


0bj:1 http://deb.debian.org/debian bullseye InRelease 
0bj:2 http://deb.debian.org/debian bullseye-updates 


Mientras esperamos a ver como termina todo esto y, InRelease 


también pendientes de una comparativa de navegadores 0bj:3 http: //security.debian.org/debian-security bullseye- 
security InRelease 


que por motivos de salud aún no ha visto la luz. Vamos a Des:4 https://deb.opera.com/opera-stable stable InRelease 
ver como instalar en Debian 11, uno de esos ie adi ) ia 
. . A es: ps: eb.opera.com/opera-stable stable/non-Tree 
navegadores que funciona muy bien, pero que no tiene amd64 Packages [1.133 B] 
un gran impacto en Linux. Hablamos de Opera, Descargados 3.723 B en 7s (517 B/s) 
el navegador web que podríamos comparar con ese 
b : . lud tira 1 fill Leyendo lista de paquetes... Hecho 
uen vecino, que siempre saluda y nunca tira las colillas Creando árbol de dependencias... Hecho 


al suelo. Leyendo la información de estado... Hecho 
Todos los paquetes están actualizados. 
rootasololinux-demo : 
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Bien, el repositorio agregado nos permite elegir entre 
y | WN el navegador Opera Estable, y el Opera Beta. No cabe 
' ' Ch INES ninguna duda que si lo quieres usar en producción, 
A !-— debes elegir la versión estable. Vemos como instalar 


Opera. 


Dove +* Instalar Opera Estable 
sudo apt-get install -y opera-stable 


Instalar Opera en Debian 11 y % Instalar Opera Beta 
. sudo apt-get install -y opera-beta 
todos sus derivados 


% 


rootesololinux-demo:-“* sudo apt-get install -y opera-stable 
Leyendo lista de paquetes... Hecho 
Creando árbol de dependencias... Hecho 


Antes de comenzar actualiza tu Debian 11 o Debian 10. Leyendo la información de estado... Hecho 


Paquetes recomendados: 
sudo apt-get update 
sudo apt-get upgrade 
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pepperflashplugin-nonfree chromium-codecs-ffmpeg-extra 
Se instalarán los siguientes paquetes NUEVOS: 
opera-stable 
O actualizados, 1 nuevos se instalarán, 0 para eliminar y 0 no actualizados. 
Se necesita descargar 77,6 MB de archivos. 
Se utilizarán 235 MB de espacio de disco adicional después de esta operación. 
etc, etc, 


MANUALES 


Encontrarás el lanzador del navegador en el menú de aplicaciones, de tu entorno de escritorio preferido. Normalmente 
en el apartado «Internet». Vemos un par de imágenes de ejemplo. 


Observa el Modo Claro. 


10) AA REVISTA SOLOLINUXN3 X  ENsolowordpress-Todo: X | MARevistaLinux - Revista 5: X | + (O PS e 
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